<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "https://www.w3.org/TR/html4/loose.dtd">
<html lang="zh-CN"><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"><meta http-equiv="Content-Language" content="zh-CN"><link href="stylesheet.css" media="all" rel="stylesheet" type="text/css">
<title>ALTER TYPE</title>
<script> var _hmt = _hmt || []; (function() { var hm = document.createElement("script"); hm.src = "https://hm.baidu.com/hm.js?d286c55b63a3c54a1e43d10d4c203e75"; var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(hm, s); })(); </script>
</head><body class="REFENTRY">
<div>
<table summary="Header navigation table" width="100%" border="0" cellpadding="0" cellspacing="0">
<tr><th colspan="5" align="center" valign="bottom">PostgreSQL 8.2.3 中文文档</th></tr>
<tr><td width="10%" align="left" valign="top"><a href="sql-altertrigger.html" accesskey="P">后退</a></td><td width="10%" align="left" valign="top"><a href="sql-altertrigger.html">快退</a></td><td width="60%" align="center" valign="bottom"></td><td width="10%" align="right" valign="top"><a href="sql-alteruser.html">快进</a></td><td width="10%" align="right" valign="top"><a href="sql-alteruser.html" accesskey="N">前进</a></td></tr>
</table>
<hr align="LEFT" width="100%"></div>
<h1><a name="SQL-ALTERTYPE"></a>ALTER TYPE</h1>
<div class="REFNAMEDIV"><a name="AEN45391"></a><h2>名称</h2>   ALTER TYPE
  &nbsp;--&nbsp;修改一个类型的定义</div>
<a name="AEN45394"></a>
<div class="REFSYNOPSISDIV"><a name="AEN45396"></a><h2>语法</h2>
<pre class="SYNOPSIS">ALTER TYPE <tt class="REPLACEABLE"><i>name</i></tt> OWNER TO <tt class="REPLACEABLE"><i>new_owner</i></tt>
ALTER TYPE <tt class="REPLACEABLE"><i>name</i></tt> SET SCHEMA <tt class="REPLACEABLE"><i>new_schema</i></tt>
  </pre>
</div>
<div class="REFSECT1"><a name="AEN45402"></a><h2>描述</h2>
<p><tt class="COMMAND">ALTER TYPE</tt> 改变一个现存类型的定义。目前能用的唯一的功能就是修改一个类型的所有者和模式。</p>
<p>要使用 <tt class="COMMAND">ALTER TYPE</tt> ，你必须拥有该类型。要修改一个类型的模式，你还必须在新模式上拥有 <tt class="LITERAL">CREATE</tt> 权限。要修改所有者，你还必须是新的所有角色的直接或间接成员，并且该成员必须在此类型的模式上有 <tt class="LITERAL">CREATE</tt> 权限。这些限制强制了修改该所有者不会做任何通过删除和重建类型不能做的事情。不过，超级用户可以以任何方式修改任意类型的所有权。</p>
</div>
<div class="REFSECT1"><a name="AEN45410"></a><h2>参数</h2>
<div class="VARIABLELIST">
<dl>
<dt><tt class="REPLACEABLE"><i>name</i></tt></dt>
<dd><p>一个需要修改的现有的类型的名字(可以有模式修饰)</p></dd>
<dt><tt class="REPLACEABLE"><i>new_owner</i></tt></dt>
<dd><p>新所有者的用户名</p></dd>
<dt><tt class="REPLACEABLE"><i>new_schema</i></tt></dt>
<dd><p>该类型的新模式</p></dd>
</dl>
</div>
</div>
<div class="REFSECT1"><a name="AEN45429"></a><h2>例子</h2>
<p>要改变一个用户定义类型 <tt class="LITERAL">email</tt> 的所有者为 <tt class="LITERAL">joe</tt> ：</p>
<pre class="PROGRAMLISTING">ALTER TYPE email OWNER TO joe;
   </pre>
<p>把用户定义类型 <tt class="LITERAL">email</tt> 的模式改变为 <tt class="LITERAL">customers</tt> ：</p>
<pre class="PROGRAMLISTING">ALTER TYPE email SET SCHEMA customers;
   </pre>
</div>
<div class="REFSECT1"><a name="AEN45439"></a><h2>兼容性</h2>
<p>SQL 标准里没有 <tt class="COMMAND">ALTER TYPE</tt> 语句。</p>
</div>
<div>
<hr align="LEFT" width="100%">
<table summary="Footer navigation table" width="100%" border="0" cellpadding="0" cellspacing="0">
<tr><td width="33%" align="left" valign="top"><a href="sql-altertrigger.html" accesskey="P">后退</a></td><td width="34%" align="center" valign="top"><a href="index.html" accesskey="H">首页</a></td><td width="33%" align="right" valign="top"><a href="sql-alteruser.html" accesskey="N">前进</a></td></tr>
<tr><td width="33%" align="left" valign="top">ALTER TRIGGER</td><td width="34%" align="center" valign="top"><a href="sql-commands.html" accesskey="U">上一级</a></td><td width="33%" align="right" valign="top">ALTER USER</td></tr>
</table>
</div>
</body></html>